package com.fowo.api.inventory.model;

import com.alibaba.excel.annotation.ExcelProperty;
import com.fowo.api.common.validator.*;
import javax.validation.constraints.*;
import lombok.Data;

/**
 * 库存库位放置变动表记录 预览导入辅助模型(全字段为文本类型)
 * @author yl_ls
 */
@Data
public class InventoryPlacementVariationImportPo {

  /** 仓库内码 */
  @ExcelProperty("仓库内码")
  @LongString(message = "仓库内码数值格式不正确", label = "仓库内码", min = 0L)
  private String stockId;

  /** 项目内码 */
  @ExcelProperty("项目内码")
  @LongString(message = "项目内码数值格式不正确", label = "项目内码", min = 0L)
  private String projectId;

  /** 物料内码 */
  @ExcelProperty("物料内码")
  @LongString(message = "物料内码数值格式不正确", label = "物料内码", min = 0L)
  private String itemId;

  /** 批号 */
  @ExcelProperty("批号")
  @Size(max = 50, message = "批号长度不能超过50")
  private String batchNo;

  /** 变动类型 */
  @ExcelProperty("变动类型")
  @Size(max = 50, message = "变动类型长度不能超过50")
  private String changeType;

  /** 变动源类型 */
  @ExcelProperty("变动源类型")
  @Size(max = 50, message = "变动源类型长度不能超过50")
  private String fromType;

  /** 变动目标类型 */
  @ExcelProperty("变动目标类型")
  @Size(max = 50, message = "变动目标类型长度不能超过50")
  private String toType;

  /** 关联单据号 */
  @ExcelProperty("关联单据号")
  @Size(max = 50, message = "关联单据号长度不能超过50")
  private String formNum;

  /** 关联制单人 */
  @ExcelProperty("关联制单人")
  @Size(max = 50, message = "关联制单人长度不能超过50")
  private String formOperator;

  /** 操作业务名称 */
  @ExcelProperty("操作业务名称")
  @Size(max = 50, message = "操作业务名称长度不能超过50")
  private String operate;

  /** 关联唯一操作键 */
  @ExcelProperty("关联唯一操作键")
  @Size(max = 50, message = "关联唯一操作键长度不能超过50")
  private String operateKey;

  /** 操作时间 */
  @ExcelProperty("操作时间")
  @DateString(message = "操作时间不是有效的日期格式")
  private String operateTime;

  /** 库位内码 */
  @ExcelProperty("库位内码")
  @LongString(message = "库位内码数值格式不正确", label = "库位内码", min = 0L)
  private String binId;

  /** 店铺id */
  @ExcelProperty("店铺id")
  @Size(max = 50, message = "店铺id长度不能超过50")
  private String shopId;

  /** fnSku */
  @ExcelProperty("fnSku")
  @Size(max = 50, message = "fnSku长度不能超过50")
  private String fnSku;

  /** 保质期(天) */
  @ExcelProperty("保质期(天)")
  @IntegerString(message = "保质期(天)数值格式不正确", label = "保质期(天)")
  private String shelfLife;

  /** 生产日期 */
  @ExcelProperty("生产日期")
  @DateString(message = "生产日期不是有效的日期格式")
  private String productionDate;

  /** 有效期至 */
  @ExcelProperty("有效期至")
  @DateString(message = "有效期至不是有效的日期格式")
  private String expiryDate;

  /** 锁库数量 */
  @ExcelProperty("锁库数量")
  @DecimalString(message = "锁库数量小数格式不正确", label = "锁库数量")
  private String lockQty;

  /** 锁库数量变更 */
  @ExcelProperty("锁库数量变更")
  @DecimalString(message = "锁库数量变更小数格式不正确", label = "锁库数量变更")
  private String changeLockQty;

  /** 在途数量 */
  @ExcelProperty("在途数量")
  @DecimalString(message = "在途数量小数格式不正确", label = "在途数量")
  private String wayQty;

  /** 在途数量变更 */
  @ExcelProperty("在途数量变更")
  @DecimalString(message = "在途数量变更小数格式不正确", label = "在途数量变更")
  private String changeWayQty;

  /** 库存数量 */
  @ExcelProperty("库存数量")
  @DecimalString(message = "库存数量小数格式不正确", label = "库存数量")
  private String stockQty;

  /** 库存数量变更 */
  @ExcelProperty("库存数量变更")
  @DecimalString(message = "库存数量变更小数格式不正确", label = "库存数量变更")
  private String changeStockQty;
}
